# PATENT APPLICATION OF

ALEXANDER E. ANDREEV 2774 Glen Firth Drive San Jose, CA 95133 Citizenship: RUSSIA

IGOR A. VIKHLIANTSEV 1341 KINGFISHER WAY SUNNYVALE, CA 94087 Citizenship: RUSSIA

VOJISLAV VUKOVIC
50 WASHINGTON STREET, APT. 9
SANTA CLARA, CA 95050
Citizenship: YUGOSLAVIA

#### ENTITLED

# DATA STREAM FREQUENCY REDUCTION AND/OR PHASE SHIFT

# DATA STREAM FREQUENCY REDUCTION AND/OR PHASE SHIFT

# FIELD OF THE INVENTION

This invention relates to signal conversion, and particularly to conversion of signals for frequency reduction and/or phase shifting.

#### BACKGROUND OF THE INVENTION

Digital circuits operate on bit signals having high and low states, often represented by "1"s and 10 The bit rate is referred to as the bit frequency, or data frequency where the bits represent In integrated circuit chips, it is common that sequential circuits operate at different frequencies (different clock rates) such that inputs of a second 15 circuit operating at one frequency receive outputs of a first circuit operating at a different frequency. the second circuit operates at frequency than the first circuit, it is quite simple convert low frequency data stream to a high 20 frequency data stream by simply inserting additional 0's into the low frequency stream. However, reversal of that conversion (i.e., to convert a high frequency data stream to a low frequency data stream) is not so easy.

Consider a circuit that operates at a given clock rate set by a clock signal, CLOCK, has data bus carrying data bits, DATA, and a port carrying valid bits, VALID, identifying whether a corresponding data bit on the data bus represents real data. The number

of bits in VALID equals the number of clock cycles. The VALID bit is true, or "1", when the associated DATA bit on the data bus represents real data, and false, or "0", when the DATA bit is not real data. The density of a data stream containing DATA is the number of appearances of 1's in VALID during some time period, T, divided by the number of clock cycles for that period. Thus the density is a number having a maximum value of 1.0 representing a maximal density when VALID = 1 on each clock cycle. Where the time 10 period T is fixed, the density may be expressed simply as the number, DENS, of appearances of 1's in the VALID signal during period T. Dividing DENS by the number of clock cycles during period T results in the actual density. For example, if there are 256 15 clock cycles in time period T and 205 of the VALID bits are 1's, the density may be expressed DENS=205, which is a density of  $\frac{205}{256} = 0.8008$ .

frequency data stream to a low frequency data stream, if the density of the high frequency data stream is low enough, the conversion might be accomplished by data compression, namely eliminating DATA bits from the high frequency data stream having associated VALID = 0 bits. For example, if a high frequency data stream contains 10 DATA bits, 0110010011, over a given period T, and the associated VALID bit stream is 1110111011, DENS = 8, and the density of the bit stream is 0.8. At high frequency f<sub>HIGH</sub>, T = 10/f<sub>HIGH</sub>.

This high frequency data stream might be converted to a low frequency data stream by compressing the data remove invalid data bits. forming the frequency data stream containing as few as 8 data bits, 01101011 having an associated VALID bit stream, 11111111. However, this type of conversion possible only if the density of the resulting low frequency data stream does not exceed 1.0, i.e., DENS  $\leq$  8, meaning that  $f_{LOW}$  must be at least as great 10 as  $0.8f_{HIGH}$  ( $f_{LOW} \ge 0.8f_{HIGH}$ ). If  $f_{LOW} < 0.8f_{HIGH}$  in the example, frequency conversion by data compression cannot be accomplished. Instead, it is common to employ a de-serialization technique to split the high frequency data stream into a plurality of 15 frequency data streams which are then applied to the output circuit.

Even if two signals have the same frequency, they may phase-shifted from each other, particularly if they employ different clock generators. In such a case, there is a need to synchronize data streams.

The present invention is directed to converter circuit that can convert a high frequency data stream to a low frequency data stream and can correct for phase shift between data streams.

## 25 SUMMARY OF THE INVENTION

20

In accordance with an embodiment of the present invention, a frequency reduction or phase shifting circuit has an input receiving an input data stream having an input frequency and a representation of

desired output frequency. A splitter splits the input data stream into a plurality of split signals each at a frequency of the desired output frequency. A plurality of catchers identify valid bits of each respective split signal. A shifter shifts valid bits identified by at least some of the catchers by a predetermined number. An output provide an output data stream at the desired output frequency.

One selected predetermined number operates the 10 circuit as a phase shifter; other predetermined numbers identify a de-serialization level for frequency reduction.

15

20

25

In some embodiments, the splitter also receives a stream of validity bits identifying which bits of the data stream are valid data. The splitter also provides validity bits to the catchers to allow the catchers to identify valid data to the shifter. The splitter operates on a split factor that is empirically derived based on the input and output frequencies and density of valid data bits in the input data stream.

In other embodiments, a process of frequency reduction and/or phase shifting for data streams is provided. In yet other embodiments, a computer program code is provides to cause a computer or processor to perform frequency reduction and/or phase shifting on a data stream.

## BRIEF DESCRIPTION OF THE DRAWINGS

- FIG. 1 is a block diagram of a signal conversion circuit according to a presently preferred embodiment of the present invention.
- FIG. 2 is a functional block diagram of a splitter used in the circuit of FIG. 1.
  - FIG. 3 is a functional block diagram of a catcher used in the circuit of FIG. 1.
- FIGS. 4 and 5, taken together, is a functional 10 block diagram of a terminal device used in the circuit of FIG. 1.

# DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS

Consider the case of a first stream at a high frequency,  $f_{\text{HIGH}}$ , having a density so high that the 15 first stream cannot be converted to frequency,  $f_{LOW}$ , by data compression without exceeding an established maximal density of DATA bits in a data stream. A circuit according to the present invention de-serializes the  $f_{\mbox{\scriptsize HIGH}}$  input stream to a k-wide stream 20 that will operate at the second clock frequency, fLOW, where  $k \ge 1$ . Thus the present invention provides a circuit architecture which reduces the high frequency data stream low frequency stream and deto a serializes the input stream to a k-wide stream. the case where k = 1, the circuit de-serializes an 25 input data stream to one having a selected phase shift. Thus the present invention also provides circuit architecture which shifts the phase of an

input data stream to synchronize the data stream to a output clock.

In the example where the VALID bit stream associated with the high frequency data stream is 1110111011, the data can be considered arranged in data packets, with each packet being identified by the number of consecutive 1's in the VALID bit stream. Hence in the example, the high frequency data stream is arranged in packets of 3, 3 and 2 bits, respectively, whereas the low frequency data stream is arranged in a single packet of 8 bits.

5

10

15

20

25

Consider a circuit operating at an input clock rate, inp CLOCK, having an input data bus receiving a bit stream, inp DATA, and an input port receiving inp VALID bits. Inp VALID is true, or "1", when real data appears on inp DATA. The density of the real data, inp DENS, is the average number of appearance of 1's on inp\_VALID during some number of input clock cycles, which for example may be 256 input clock cycles (although any number of clock cycles may be employed for defining inp DENS). The data stream may be uniform or not. The length of a data packet (the number of consecutive 1's in inp VALID) is denoted by burst depth. The frequency of inp CLOCK is denoted by inp\_frq and the frequency of out CLOCK is denoted by out frq.

FIG. 1 is a block diagram of circuit architecture for converting a data stream at an input clock signal frequency, inp\_CLOCK, to an output clock

signal frequency, out\_CLOCK. The circuit includes a splitter 10 that receives inp\_CLOCK, as well as the inp\_VALID and inp\_DATA streams. Splitter 10 splits the input clock stream, inp\_CLOCK, into n split\_CLOCK streams and splits the input data stream, inp\_DATA, into n split\_DATA streams, for respective ones of n catchers 12. The term n is a split\_factor that is empirically derived for the specific circuit. For example, one a suitable calculation for split\_factor for the 256 input clock cycles might be a rounding up to the nearest integer of:

$$split\_factor = 3.0 * \left(\frac{inp\_frq}{out\_frq}\right) * \left(\frac{inp\_DENS}{256}\right) + 1 + burst\_depth$$
.

Split\_factor  $n \ge 2$ , because burst\_depth  $\ge 1$ .

10

15

20

25

Catchers 12 synchronize the plural split CLOCK streams from splitter 10 to the output clock frequency of out CLOCK, which is the output clock frequency. The n data bits from splitter 10 are supplied by respective catchers 12 to shifter 14 at the clock rate of out CLOCK. The n valid bits from catchers 12 are also supplied to shifter Shifters 14 and 16 cyclically shift indices of the respective streams based on a de-serialization factor The shifted streams are accumulated by k-terminal 20 to derive the output valid stream and k-wide data streams.

The logic of splitter 10 is shown in greater detail in FIG. 2. Splitter 10 includes an input bus that receives the inp\_DATA stream, an input port that

receives the inp\_VALID stream and output registers that provide split\_DATA[i] and split\_CLOCK[i] output streams, where  $0 \le i < n$ . For ease of explanation of the logic illustrated in FIG. 2, splitter 10 also includes n auxiliary registers circle[i]. The term next\_circle[i] identifies the output nets for each index i. Although splitter 10 is herein described as employing physical output and auxiliary registers, the function described in association with FIG. 2 may be performed by a processor operating under the control of suitable program code, without regard to the physical attributes of the processor.

Upon receipt of the a first (i=0) inp\_CLOCK bit, the n circle[i] registers are initialized to logical 0: circle[0]=0, circle[1]=0,..., circle[n-1]=0. Upon receipt of the a the next (i=1) inp\_CLOCK bit, the net for index 0 is set to the negation of register circle[n-1] and the net for index 1 is set to the negation of register circle[0]:

20  $next \_circle[0] = \neg circle[n-1]$  $next \_circle[1] = \neg circle[0],$ 

10

15

where  $\neg$  denotes a negation. In the example, next\_circle[0]=1 and next\_circle[1]=1. Additionally, values of enable bits en[0] and en[1] are logically derived as

 $en[0] = (\neg circle[0].Q) \ AND \ inp \ VALID$   $en[1] = (circle[1].Q) \ AND \ inp \ VALID,$ 

where .Q identifies the output of the respective register. In the example,

en[0] = 1, if inp\_VALID = 1,
en[0] = 0, if inp\_VALID = 0,
en[1] = 0, if inp\_VALID = 1,
en[1] = 1, if inp\_VALID = 0.

At step 202, the value of i is set to 2, and at step 204 the value of i is compared to the value of the split\_factor (n). If i is smaller than the split\_factor, such as if n≥3, then at step 206, the net of index i is set to the output of the circle[i] register,

# $next \_circle[i] = circle[i].Q,$

and the value of enable bit en[i] is logically derived as

$$en[i] = circle[i].Q \ AND \ inp \ VALID$$
.

15 In the example, if  $n \ge 3$ ,

etc.

The value of i is then incremented at step 208 (i=i+1) and the process returns to step 204. Thus, the loop formed by steps 204-208 generate values for the nets of successive indices i and successive bit values for enable bits en[i] for each value of i=3,4,...,(n-1), where  $n\geq 3$ .

If at step 204 the value of i is not smaller than the split\_factor, then the value of i is reset to 0 at step 210. At step 212, if the value of i is smaller than the split\_factor, such as if i≠n, then at step 214 the value of the split CLOCK[i] input bit to

is logically derived as the EXCLUSIVE-OR of the output from the split\_CLOCK[i] register and enable bit en[i].

 $split \_CLOCK[i].D = split \_CLOCK[i].Q^n[i],$ 

5 where ^ is EXCLUSIVE-OR, and .D is the register input. For example, since split\_CLOCK[0] register was initialized to 0, a "1" is supplied to the input of the split\_CLOCK[0] register if inp\_VALID is "1"; otherwise, a "0" is supplied to the split\_CLOCK[0] register.

The value of the split\_DATA[i] input bit is logically derived as either the negation of enable bit en[i] anded with the output from the split\_DATA[i] register, or the enable bit en[i] anded with the inp\_DATA bit.

$$split \_DATA[i].D = \{ (\neg en[i])AND \ split \_DATA[i].Q \}$$

$$OR \ \{ en[i] \ AND \ inp \quad DATA \}.$$

15

25

In the example, the split\_DATA[0] bit will take the value of the inp\_DATA[0] bit if inp\_VALID=1 or will take the value 0 otherwise.

Additionally, the input to the circle[i] register is logically derived as either the negation of the inp\_VALID bit anded with the output of the circle[i] register, or the inp\_VALID bit anded with the value of the net of index i.

$$circle[i].D = \{(\neg inp \_VALID) \ AND \ circle[i].Q\}$$

$$OR \{inp \_VALID \ AND \ next \_ circle[i]\}.$$

In the example, for i=0 the output of the circle[0] register will be 1 if inp VALID=1, or 0 otherwise.

At step 216 the value of i is incremented by 1 and the process loops back to step 212 to consider the next value of i. If at step 212 the value of i is not smaller than split\_factor n, such as if i=n, the process continues to the next inp CLOCK cycle.

Consider the example of split-factor = n = 2. and a data stream sequence of a0,a1,a2,a3,a4,a5,.... Assume also that bit a2 is not valid data, so the inp VALID stream is 1,1,0,1,1,1,... Since n=2, there are only two split\_DATA stream outputs, split\_DATA[0] 10 split DATA[1], and and two split split CLOCK[0] and split CLOCK[1]. Since i=2 from step 202, i is not smaller than n at step 204, so the process omits the loop formed by steps 206 and 208. 15 At step 218, the value of en[0] is 1 (because inp\_VALID=1), and the value of split\_DATA[0] is the value of inp DATA[0]=a0. The value of split CLOCK[0] is 1. At the next input clock, i is incremented at step 216 (i.e., to i=1). At step 214,  $inp_VALID=1$ , so split DATA[1]=a1 and split CLOCK[1]=1. 20 At the next input clock (i=2)with inp VALID=0, split\_DATA[0]=0 and split CLOCK[0]=0. The process continues through the input data stream so that split\_DATA[0]=a0,0,a4,... and split DATA[1]=a1,a3,a5..., 25 split\_CLOCK[0]=1,0,1,... and split CLOCK[1]=1,1,1,...

Where n is some greater number, such as n=3, there are n split\_DATA streams and split\_CLOCK streams derived in the same manner, and the states of the auxiliary registers and enable bits are

established by the loop of steps 204, 206 and 208. Thus, where n=3 and for the example given where data bit a2 is not valid, split\_DATA[0]=a0,a3,..., split\_DATA[1]=a1,a4,... and split\_DATA[2]=0,a5,..., and split\_CLOCK[0]=1,1,..., split\_CLOCK[1]=1,1,... and split\_CLOCK[2]=0,1,....

FIG. 3 is a logical flow diagram of a catcher 12 that synchronizes the input data stream at a clock rate split\_CLOCK[i] to clock rate out CLOCK. to each catcher 12 are out CLOCK and the respective split DATA[i] and split CLOCK[i]. Each catcher 12 includes a clock value auxiliary register and counter, as well as a split DATA output register and a catched valid output. To synchronize the input data stream to out\_CLOCK, a value corresponding the out CLOCK clock rate is input to the clock value register. Upon receipt of the next out CLOCK signal, if the split CLOCK rate is equal to the output of the clock value register at step 300, the counter is set to 0 at step 302, and the split CLOCK rate established by the out\_CLOCK rate in the clock\_value register.

10

15

20

If at step 300 the split\_CLOCK rate is not equal to the out\_CLOCK rate set in the clock\_value register, the count in the counter is incremented at step 304. At step 306, if the count in the counter is equal to 1, then at step 308 split\_DATA is input to the split\_DATA register, and the catched\_valid bit

is set to true or 1. Thus, the split\_DATA register contains valid data.

If at step 306 the count in the counter is not then at step 310 the decision is made as to whether the count in the counter is 3. If the count 3 (i.e., it is 2) the process outputs catched DATA in the form of the split DATA in the split\_DATA register in synchronous with the value established by the clock value register, and the next out CLOCK signal increments the count in the counter step 306. With count in the the incremented to 3, at step 312 the catched DATA register and counter are reset to 0, the valid bit is set to 0 and the split CLOCK rate is input to the clock value register. At the next out CLOCK signal, the counter is incremented to 1 and the process continues.

10

15

Each shifter 14 and 16 simply shifts the indices based on a value of SHIFT from terminal 18. More 20 particularly, shifter 14 receives the catched DATA from each of the n catchers 12 to reassemble a data stream having n bits shifted DATA[0],..., shifted DATA[n-1]. The output of shifter 14 is a shifted data stream of k valid data bits to terminal 25 Similarly, shifter 16 receives the catched VALID bits from catchers 12 in the form shifted VALID[0], ..., shifted VALID[n-1], and supplies a shifted stream of k valid bits to terminal 18.

Each shifter 14, 16 cyclically (based on the shift\_factor n) shifts indices of the input array, A[i] to the output array Z[i] based on the value of SHIFT.

 $Z[i] = A[i + SHIFT \% split \_ factor],$ 

15

20

25

where  $0 \le i < split_factor$ . The number of multiplexers in each shifter 14, 16 is

depth \* split factor \* width,

where depth is number of digits for SHIFT and width 10 is the width of the bus.

FIGS. 4 and 5, taken together, are a logical flow diagram of terminal 18. Terminal 18 accumulates k valid bits and then recalculates a new SHIFT (value k) for shifters 14 and 16. Terminal 18 has k outputs, which are outputs of k consistent catchers 12. Thus for shift = 0, terminal 18 provides outputs of first k catchers, for shift = k the circuit's outputs are outputs of next k catchers and so on. Hence, the output is a k-wide data stream at out\_CLOCK frequency

Terminal circuit 18 assigns the first k outputs of the n data outputs from data shifter 14, and adds value k to the shift. Thus for shift = 0 the circuit's outputs are outputs of first k catchers 12, for shift = k the terminal circuit outputs are outputs of next k catchers and so on. Terminal 18 has k inputs tvalid[0], ..., tvalid[k-1] (first k outputs of valid shifter 16), k input data buses tdata[0],..., tdata[k-1] (first k outputs of data

shifter 14), valid\_count register, k data output registers and a SHIFT output register. Terminal 18 also has k auxiliary registers data\_buf and a cur\_valid register.

At step 400, the contents of the valid\_count register and cur\_valid register are initialized to 0, i is set to 0, and the input to the SHIFT register is set equal to its output. If, at step 402, i < k, the DATA[i] output register is set to 0 and the input to data\_buf[i] register is set to its output at step 404, and i is incremented by 1 at step 406. The loop formed by steps 402-406 is repeated until i is not smaller than k (i.e., i = k).

Consider the case where k = 2 for block 408 in 15 FIG. 4. If at step 410 the valid count register is 1, then the cur\_valid register is set to tvalid[0] at step 412 and the process continues to step 418. Ιf at step 410 the valid count register is not contain 1, then at step 414 if valid\_count register contains 0 and if tvalid[1]! is not equal to 0, then the 20 cur valid register is set to a sum of tvalid[0] and tvalid[1] at step 416, and the process continues to step 418. If at step 414 valid count is not 0 (i.e., is 2) or if tvalid[1]! is 0, the process continues to Thus, for k = 2, block 408 provides an 25 step 418. output of cur\_valid = 0 if either valid\_count ≠ 0 or if tvalid[0] = 0 (step 414), a cur value equal to tvalid[0] if valid count = 1 (step 412), or a cur\_valid = tvalid[1] + 1 if valid count = 0 and

tvalid[0]! = 0 (where any tvalid[i] is one bit, tvalid[1] = 1) (steps 414 and 416). Hence, for k = 2 and tvalid[i] being one bit,  $cur_valid[i]$  may be either 0, 1 or 2.

At step 418 the value of cur\_valid from block 5 408 is added to valid count and to SHIFT to derive a value plus value and a shift plus value, respectively. at step 420 cur value Ιf is greater than 0 (i.e., cur value equals 0), process continues to step 422 (FIG. 5). If at step 10 420 cur\_value is greater than 0, then if shift plus is smaller than split\_factor at step 424, the value of SHIFT is set to shift plus at step 426. Otherwise, if shift plus is not greater than split\_factor, the value of SHIFT is set to shift\_plus 15 minus shift\_factor at step 428.

The result of the loops of steps 420, 424, 426 and 428 is setting of a value of SHIFT as the value initially established at step 400 (if cur\_value = 0), the value of shift\_plus (if cur\_value > 0 and shift\_plus < split\_factor) or the value of shift\_plus plus split\_factor (if cur\_value > 0 and shift\_plus > split\_factor). The value of SHIFT is supplied by terminal 18 to shifters 14 and 16 (FIG. 1) as k.

20

25 Continuing the process of termination circuit 18 at FIG. 5, at step 422 i is set to 0 and a loop formed of steps 430, 432, 434 and 436 is followed to set the output data register DATA[i] for each index i until i = k. More particularly, at step 430, if i is

smaller than k, then at step 432 if cur\_valid is greater than 0 and if valid\_plus equals k, the content of the data\_buf register is input to the applicable DATA[i] register at step 434, and the value of i is incremented at step 436. On the other hand, if at step 432 cur\_valid is not greater than 0 (i.e., cur\_valid=0) and/or if valid\_plus does not equal k (valid\_plus  $\neq$  k), the process steps directly to step 436.

10 When i is incremented to the value of k as identified at step 430, then at step 438, i is again set to 0 for another loop formed of steps 440-458. More particularly, at step 440, if i is not smaller than k (i.e., if  $i \ge k$ ), then the process steps to the next out\_CLOCK. If i is smaller than k, then at step 15 442 an index j is set to 0. If at step 444, j is smaller than or equal to i (not greater than i), a decision step 446 identifies if the output of the valid count register is equal to i - j and cur\_value > 0. If the condition at step 446 is true, 20 then if at step 448 valid\_plus is equal to k, the value of tdata[j] is input to data register DATA[i] at step 450, where tdata[j]  $\in$  DATA[i], and j  $\leq$  i. the other hand, if the condition at step 446 is true and if at step 448 valid\_plus is not equal to k, then 25 if at step 452 valid plus > i, data buf[i] is loaded with tdata[j] at step 454.

If the condition at step 446 is false, or upon establishing a value for DATA[i] at step 450 or a

value for data\_buf[i] at step 454, or if valid\_plus is not greater than i (e.g., valid\_plus  $\leq$  i), index j is incremented at step 456 and the process returns to step 444 to determine if j  $\leq$  i. If through the loop formed by steps 446-454 index j is incremented at step 456 so that j > i, then the process loops to increment i at step 458 and return to step 440.

Consider the case of k=2. Steps 440-458 perform the following functions: In a first stage when valid\_count.Q = 0, three conditions can occur:

- 1. If both inputs tvalid[0] and tvalid[1] equal 1, cur\_valid = 2 and both inputs are coupled to the outputs (DATA[0] = tdata[0] and DATA[1] = tdata[1]), and the process of the first stage is repeated.
- 2. If tvalid[0] = 1 and tvalid[1] = 0,
  cur\_valid = 1 and tdata[0] is stored
  (data\_buf[0] = tdata[0]), and the process goes
  to the second stage (valid\_count = 1).
- 3. If tvalid[0] = 0, the process simply stays in the present stage.

15

In a second stage when valid\_count.Q = 1,
cur\_valid = tvalid[0], and the states of tvalid[0]
and tdata[0] are considered:

1. If tvalid[0] = 1, (cur\_valid = 1),
input data tdata[0] is output DATA[1] (DATA[1] =
 tdata[0]) and the process advances to the first
 (or next) stage.

2. If tvalid[0] = 0 (cur\_valid = 0), the
process remains in the present stage.

Hence, when in a given stage M, M real values are accumulated on data\_buf, and when k values are accumulated, they are output. In the process of steps 440-458, as long as j is not greater than i (in which case i is incremented to be greater than j) index j is either i or i-1. Consequently, for a current stage for index i, tdata[j] is either DATA[i] or DATA[i-1]. If tdata[j] is DATA[i-1], it had been stored as buf\_data[i] in the prior stage.

10

15

20

25

It will be appreciated, that additional stages are necessary for other values of k. Thus, in the description given for the second stage, if tvalid[0] = 1 and DATA[1] = tdata[0], for k > 2 the process advances to the next stage, rather than to the first stage.

The present invention thus provides a circuit for converting high frequency data streams to low frequency and for phase matching a data stream to a clock of a sequential circuit. The circuit comprises a SPLITTER circuit that splits the incoming data stream into a plurality of n split data streams at the output phase and frequency, n CATCHER circuits, two SHIFTER circuits, one for data and one for valid and one k TERMINAL circuit. The splitter operates on a split\_factor, n, which is empirically derived for the specific circuit. The serialization level, k, identifies the width of the

output stream. The circuit is particularly advantageous in that it can handle phase shifting without frequency conversion by setting k=1.

The invention also provides a process of frequency reduction and/or phase shifting of a data stream. In one embodiment, the invention is carried out in a computer or processor operating under control of a computer readable program containing code that is stored on a computer readable medium, such as a recording disc, to cause the computer or processor to carry out frequency reduction and/or phase shift of a data stream.

Although the present invention has been described with reference to preferred embodiments, workers skilled in the art will recognize that changes may be made in form and detail without departing from the spirit and scope of the invention.

5

10